## Module Descriptor 2018/19 School of Computer Science and Statistics. | Module Code | CS4021/4521 | |-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Module Name | Advanced Computer Architecture | | Module Short<br>Title | n/a | | ECTS weighting | 5 | | Semester/term taught | Semester 1 | | Contact Hours | Lecture hours 27 Lab hours 0 Tutorial hours: 6 Total hours: 33 + Coursework | | Module<br>Personnel | Dr Jeremy Jones | | Learning<br>Outcomes | <ol> <li>use Spin to check the correctness of parallel algorithms</li> <li>implement and evaluate a selection of lock algorithms</li> <li>implement and evaluate a selection of lockless algorithms</li> <li>describe the operation of hardware transactional memory</li> <li>implement and evaluate a selection of lockless algorithms that make use of hardware transaction memory</li> </ol> | | Module<br>Learning Aims | To provide students with theoretical and practical experience of concurrent programming with and without locks. | | Module<br>Content | <ul> <li>simple locks</li> <li>using Spin to check the correctness of parallel algorithms</li> <li>IA32 and x64 atomic and serialising instructions</li> <li>load locked / store conditional (LL/SC) instructions</li> <li>the impact of cache coherency</li> <li>the cost of sharing data between threads in a multiprocessor</li> <li>lock implementations and their evaluation (eg. testAndSet, testAndTestAndSet, ticket, MCS, Peterson,)</li> <li>the compare and swap instruction</li> <li>lockless algorithms [eg. a Trieber Stack, lockless ordered lists,]</li> <li>memory ordering and consistency</li> <li>the ABA problem</li> <li>memory management for lockless algorithms [eg. Hazard pointers]</li> <li>hardware transactional memory [eg Intel Haswell CPUs]</li> <li>hardware lock elision</li> </ul> | | Recommended<br>Reading List | <ul> <li>The Art of Multiprocessor Programming, Maurice Herlihy and Nir Shavit</li> <li>The Spin Model Checker: Primer and Reference Manual, Gerald J. Holzmann</li> <li>Principles of the Spin Model Checker, Mordechai Ben-Ari</li> </ul> | | Module Pre | CS3021 CS3421 | ## Module Descriptor 2018/19 School of Computer Science and Statistics. | Requisite | | |------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Module Co<br>Requisite | | | Assessment<br>Details | Annual assessment Exam (2 hrs): 80% typically answer 3 out of 4 questions Coursework: 20% Supplemental assessment is by examination ONLY (100%). Students repeating 'offbooks' (OBA) are also assessed by examination ONLY (100%) in all examination sessions. | | Module approval date | August 2012 | | Approved By | Jeremy Jones | | Academic Start<br>Year | 2012 | | Academic Year of Data | 2018/19 | | Website | https://www.scss.tcd.ie/Jeremy.Jones/CS4021/CS4021.htm |